WorkManager 在多进程应用中的高级用法
在 WorkManager 2.5 中,我们让多进程应用能够更容易地访问在指定进程中运行的特定 WorkManager 实例。
现在,我们更是在 WorkManager 2.6 中进一步增加了能够让 Worker 在任意进程中运行的支持,并且能将 Worker 绑定到指定的进程。多进程支持对于需要在多个进程中运行 Worker 的应用非常有用。虽然大多数应用只需要一个进程就能良好地工作,但有些应用则需要多个进程来完成它们的工作,这在过去很难管理不同进程之间的工作,但现在一切都不一样了!
从 WorkManager 2.6 开始,您可以使用 RemoteListenableWorker 或 RemoteCoroutineWorker 将 Worker 绑定到特定进程。如果您使用 Kotlin 来实现 Worker,请使用 RemoteCoroutineWorker,而其他情况则使用 RemoteListenableWorker。在本文中我们的示例将使用 Kotlin 来实现,我们也在下面的示例链接中提供了相似的 Java 实现。
RemoteListenableWorker
https://developer.android.google.cn/topic/libraries/architecture/workmanager/advanced/listenableworker?hl=zh_cnRemoteCoroutineWorker
https://developer.android.google.cn/topic/libraries/architecture/workmanager/advanced/coroutineworker#remotecoroutineworker
RemoteCoroutineWorker 实现起来和 CoroutineWorker 很相像,但不用覆写 `doWork`,而是覆写 `doRemoteWork`,并在生成 WorkRequest 时将 ARGUMENT_CLASS_NAME 和 ARGUMENT_PACKAGE_NAME 两个参数传入 InputData 来将其绑定到特定进程。
val PACKAGE_NAME = "com.example.background.multiprocess"
// RemoteWorkerService 被添加到应用的 AndroidManifest.xml
val serviceName = RemoteWorkerService::class.java.name
val componentName = ComponentName(PACKAGE_NAME, serviceName)
val data: Data = Data.Builder()
.putString(ARGUMENT_PACKAGE_NAME, componentName.packageName)
.putString(ARGUMENT_CLASS_NAME, componentName.className)
.build()
return OneTimeWorkRequestBuilder<ExampleRemoteCoroutineWorker>
.setInputData(data)
.build()
CoroutineWorker
https://developer.android.google.cn/topic/libraries/architecture/workmanager/advanced/coroutineworker
<manifest ... >
<service
android:name="androidx.work.multiprocess.RemoteWorkerService"
android:exported="false"
android:process=":worker1" />
<!-- RemoteWorkerService2 extends RemoteWorkerService -->
<service
android:name=".RemoteWorkerService2"
android:exported="false"
android:process=":worker2" />
...
</manifest>
WorkManager 多进程示例
https://github.com/android/architecture-components-samples/tree/main/WorkManagerMultiprocessSample发布说明
https://developer.android.google.cn/jetpack/androidx/releases/work#version_260_2提交到我们公开的问题跟踪器
https://issuetracker.google.com/issues/new?component=409906
欢迎您通过下方二维码向我们提交反馈,或分享您喜欢的内容、发现的问题。您的反馈对我们非常重要,感谢您的支持!
推荐阅读